import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '@/views/Home.vue'

Vue.use(VueRouter)

const routerPush = VueRouter.prototype.push
VueRouter.prototype.push = function (location) {
  return routerPush.call(this, location).catch((err) => {})
}

const routes = [
  {
    path: '/',
    redirect: Home
  },
  {
    path: '/home',
    name: 'home',
    component: Home
  },
  {
    path: '/goods',
    name: 'goods',
    component: () => import('@/views/Goods.vue')
  },
  {
    path: '/user',
    name: 'user',
    component: () => import('@/views/User.vue'),
    redirect: '/user/cart',
    children: [
      {
        path: 'cart',
        name: 'cart',
        component: () => import('@/components/user/Cart.vue')
      }
    ]
  },
  {
    path: '/order',
    name: 'order',
    component: () => import('@/views/Order.vue')
  },
  {
    path: '/free',
    name: 'free',
    component: () => import('@/views/Free.vue')
  },
  {
    path: '/details',
    name: 'details',
    component: () => import('@/views/Details.vue')
  },
  {
    path: '*',
    name: 'error',
    component: () => import('@/components/Error.vue')
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

export default router
